import java.util.Arrays;

/**
 * 646.最长数对链
 */
public class Exerciser4 {
    public int findLongestChain(int[][] pairs) {
        // 对其进行 升序 排序
        Arrays.sort(pairs, (a, b) -> a[1] - b[1]);

        int n = pairs.length;
        int[] dp = new int[n];
        for(int i = 0;i < n;i++) {
            dp[i] = 1;
        }
        int ret = 1;
        for(int i = 1;i < n;i++) {
            for(int j = i;j >= 0;j--) {
                if(pairs[j][1] < pairs[i][0]) {
                    dp[i] = Math.max(dp[j] + 1,dp[i]);
                }
            }
            ret = Math.max(dp[i],ret);
        }
        return ret;
    }
}
